## TMC2301

## Image Resampling Sequencer <br> 15, 18, 20 MHz

## Features

- Rotation, warping, panning, zooming, and compression of images in real time
- 20 MHz clock rate
- 4096 x 4096 image field addressing capability
- User-selectable nearest-neighbor, bilinear interpolation, and cubic convolution resampling algorithms
- Static convolutional filtering of up to $16 \times 16$ pixel windows
- Single-pass or two-pass convolution operations
- Low power consumption CMOS process
- Single 5 V power supply
- Available in a 68 -pin grid array and low-cost plastic leaded chip carrier (J-bend)


## Description

The TMC2301 is a VLSI circuit which supports image resampling, rotation, rescaling and filtering by generating input bit plane, interpolation coefficient lookup table, and output bit plane memory addresses along with external multiplier-accumulator control signals. The TMC2301 can process data fields of up to $4096 \times 4096$ multibit words at a clock rate of up to 20 MHz . An Image Resampling

## Logic Symbol



## Applications

- Video special-effects generators
- Image recognition systems, robotics
- Artificial intelligence
- High-precision image registration (LANDSAT processing)
- High-speed data encoding/decoding
- General purpose image processing
- Image data compression

Sequencer (IRS) based system can nearest-neighbor resample a $512 \times 512$ image in 15 milliseconds, translating, zooming, rotating, or warping it, depending on the transform parameter set loaded. A complete bilinear interpolation of the same image can be completed in 60 milliseconds. Image resampling speed is independent of the angle of rotation, degree of warp, or amount of zoom specified.

A high performance, TMC2301-based system can execute bilinear and cubic convolution algorithms that rotate images accurately and in real time. Keystone or other perspective correction, image plane distortion, and numerous other second order polynomial transformations can be programmed and executed under direct user control. Direct access to the interpolation coefficient lookup table allows dynamic modification of the algorithm.

Following an initialization with the transform parameters and control bits defining the operation to be executed, the IRS assumes control of the input and output data fields and executes unattended. All inputs except INTER and all outputs are registered on the rising edge of clock. All outputs are three-state controlled except $\overline{\mathrm{ACC}}, \overline{\text { CZERO }}$, END, and DONE.

Fabricated in a 1 micron CMOS process, the TMC2301 operates at clock rates of up to 20 MHz over the full commercial ( 0 to $70^{\circ} \mathrm{C}$ ) temperature and supply voltage ranges, and at 15 MHz over the extended $\left(-55\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$ temperature and supply voltage ranges. All signals are TTL compatible.

## Block Diagram



## Functional Description

## General Information

The IRS is a versatile self-sequencing address generator designed primarily to filter a two-dimensional image or to remap and resample it from one set of Cartesian coordinates ( $\mathrm{x}, \mathrm{y}$ ) into a new transformed set ( $\mathrm{u}, \mathrm{v}$ ). Most applications use two identical devices in tandem, one generating the row coordinates ( X and U ), the other generating the column coordinates ( Y and V ). The algorithm performed by the TMC2301 consists of two steps: a coordinate system transformation, followed by pixel interpolation. Interpolation is necessary when the transformed pixel positions ( $\mathrm{U}, \mathrm{V}$ ) do not coincide with the original pixel positions ( $\mathrm{X}, \mathrm{Y}$ ). The new pixel intensity values are obtained by interpolating the original pixels in the neighborhood of the transformed pixel positions. See Figure 1.

The IRS executes a general second order coordinate transformation of the form:

$$
\begin{aligned}
& X(u, v)=A u^{2}+B u+C u v+D v^{2}+E v+F \\
& Y(u, v)=G u^{2}+H u+K u v+L v^{2}+M v+N
\end{aligned}
$$

where A through N are user-defined parameters. It steps sequentially through the pixels of a user-defined rectangle in
the new set of coordinates, computing the "old" address (X, Y) corresponding to each "new" location (U, V).

The TMC2301 uses the external multiplier-accumulator, connected to the system clock, to calculate the interpolated pixel value by summing the products of the original pixel values stored in the source buffer RAM and the appropriate weights from the polynomial transform lookup table. The new interpolated image value is then stored in the corresponding (U, V) memory location. Finally, the new image address is incremented by one pixel in the " U " direction or reset to the start of the next line (with "V" incremented) proceeding line-by-line through the entire destination image.

The TMC2301 can support any nearest neighbor, bilinear, or cubic resampling, according to the user's requirements. The bilinear and cubic kernels require a coefficient lookup table and multiplier-accumulator. Both one-pass and two-pass algorithms are supported. Sophisticated "walkaround" algorithms implementing static filters are also easily realized utilizing convolutional kernels of up to $16 \times 16$ pixels. For each output point in a typical static single-pass filter, the IRS will generate a series of addresses, "walking" around that point in two dimensions. At the end of each walk, it will advance one pixel along the output scan line, then begin the walk for the next pixel.


Figure 1. Image Resampling Geometry Showing Image Rotation and Expansion

A basic TMC2301-based system is shown in Figure 2. In this typical system, two Image Resampling Sequencers process the image. The only other external parts needed are a
multiplier-accumulator, external interpolation coefficient lookup table RAM, and the user-specified Source and Destination Image Memory.


Figure 2. Basic 2-D Image Convolver Using TMC2301 Image Resampling Sequencer Utilizing Typical 8-Bit Data Path

## Pin Assignments

## 68 Pin Grid Array



| Pin | Name | Pin | Name | Pin | Name | Pin | Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| B2 | INIT | K2 | $\mathrm{U}_{10}$ | K10 | $\mathrm{X}_{1}$ | B10 | $\mathrm{P}_{6}$ |
| B1 | $\overline{\text { OETA }}$ | L2 | $U_{11}$ | K11 | $\mathrm{X}_{2}$ | A10 | $\mathrm{P}_{5}$ |
| C2 | INTER | K3 | UWRI | J10 | $\mathrm{X}_{3}$ | B9 | $\mathrm{P}_{4}$ |
| C1 | END | L3 | $\overline{\text { ACC }}$ | J11 | $\mathrm{X}_{4}$ | A9 | $\mathrm{P}_{3}$ |
| D2 | DONE | K4 | $\overline{\text { CZERO }}$ | H10 | $\mathrm{X}_{5}$ | B8 | $\mathrm{P}_{2}$ |
| D1 | $\mathrm{U}_{0}$ | L4 | $\mathrm{CA}_{0}$ | H11 | $\mathrm{X}_{6}$ | A8 | $\mathrm{P}_{1}$ |
| E2 | $U_{1}$ | K5 | $\mathrm{CA}_{1}$ | G10 | $\mathrm{X}_{7}$ | B7 | P0 |
| E1 | $\mathrm{U}_{2}$ | L5 | $V_{D D}$ | G11 | $\mathrm{X}_{8}$ | A7 | CLK |
| F2 | GND | K6 | GND | F10 | GND | B6 | GND |
| F1 | $\mathrm{U}_{3}$ | L6 | $\mathrm{CA}_{2}$ | F11 | X9 | A6 | $V_{D D}$ |
| G2 | $\mathrm{U}_{4}$ | K7 | $\mathrm{CA}_{3}$ | E10 | $\mathrm{X}_{10}$ | B5 | $\overline{\text { NOOP }}$ |
| G1 | $\mathrm{U}_{5}$ | L7 | $\mathrm{CA}_{4}$ | E11 | $\mathrm{X}_{11}$ | A5 | LDR |
| H2 | $\mathrm{U}_{6}$ | K8 | $\mathrm{CA}_{5}$ | D10 | $\mathrm{P}_{11}$ | B4 | B0 |
| H1 | $\mathrm{U}_{7}$ | L8 | $\mathrm{CA}_{6}$ | D11 | $\mathrm{P}_{10}$ | A4 | $\mathrm{B}_{1}$ |
| J2 | $\mathrm{U}_{8}$ | K9 | $\mathrm{CA}_{7}$ | C10 | P9 | B3 | B2 |
| J1 | $\mathrm{U}_{9}$ | L9 | $\mathrm{X}_{0}$ | C11 | $\mathrm{P}_{8}$ | A3 | B3 |
| K1 | GND | L10 | GND | B11 | $\mathrm{P}_{7}$ | A2 | $\overline{\text { WEN }}$ |

## 68 Pin PLCC



65-2301-04

| Pin | Name | Pin | Name | Pin | Name | Pin | Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | GND | 18 | GND | 35 | GND | 52 | GND |
| 2 | $\mathrm{CA}_{2}$ | 19 | X9 | 36 | VDD | 53 | $\mathrm{U}_{3}$ |
| 3 | $\mathrm{CA}_{3}$ | 20 | $\mathrm{X}_{10}$ | 37 | NOOP | 54 | $\mathrm{U}_{4}$ |
| 4 | $\mathrm{CA}_{4}$ | 21 | $\mathrm{X}_{11}$ | 38 | LDR | 55 | $U_{5}$ |
| 5 | $\mathrm{CA}_{5}$ | 22 | $\mathrm{P}_{11}$ | 39 | B0 | 56 | $U_{6}$ |
| 6 | $\mathrm{CA}_{6}$ | 23 | $\mathrm{P}_{10}$ | 40 | B1 | 57 | $\mathrm{U}_{7}$ |
| 7 | $\mathrm{CA}_{7}$ | 24 | P9 | 41 | B2 | 58 | $\mathrm{U}_{8}$ |
| 8 | $\mathrm{X}_{0}$ | 25 | $\mathrm{P}_{8}$ | 42 | B3 | 59 | $U_{9}$ |
| 9 | GND | 26 | $\mathrm{P}_{7}$ | 43 | WEN | 60 | GND |
| 10 | $\mathrm{X}_{1}$ | 27 | $\mathrm{P}_{6}$ | 44 | INIT | 61 | $\mathrm{U}_{10}$ |
| 11 | $\mathrm{X}_{2}$ | 28 | $\mathrm{P}_{5}$ | 45 | OETA | 62 | $\mathrm{U}_{11}$ |
| 12 | $\mathrm{X}_{3}$ | 29 | P4 | 46 | INTER | 63 | UWRI |
| 13 | $\mathrm{X}_{4}$ | 30 | $\mathrm{P}_{3}$ | 47 | END | 64 | $\overline{\text { ACC }}$ |
| 14 | $\mathrm{X}_{5}$ | 31 | $\mathrm{P}_{2}$ | 48 | DONE | 65 | CZERO |
| 15 | $\mathrm{X}_{6}$ | 32 | $\mathrm{P}_{1}$ | 49 | $\cup_{0}$ | 66 | $\mathrm{CA}_{0}$ |
| 16 | $\mathrm{X}_{7}$ | 33 | P0 | 50 | $\mathrm{U}_{1}$ | 67 | $\mathrm{CA}_{1}$ |
| 17 | $\mathrm{X}_{8}$ | 34 | CLK | 51 | $\mathrm{U}_{2}$ | 68 | $V_{D D}$ |

## Pin Descriptions

| Pin Name | Pin Nu | umber | Pin Function Description |
| :---: | :---: | :---: | :---: |
|  | PGA | PLCC |  |
| Power |  |  |  |
| GND | $\begin{aligned} & \text { F2, F10, K1, } \\ & \text { K6, L10, B6 } \end{aligned}$ | $\begin{gathered} 1,9,18,35 \\ 52,60 \end{gathered}$ | Supply Voltage. The TMC2301 operates from a single +5 V supply. All pins must be connected. |
| VDD | L5, A6 | 36, 68 | Ground. The TMC2301 operates from a single +5 V supply. All pins must be connected. |
| Clock |  |  |  |
| CLK | A7 | 34 | System Clock. The TMC2301 has a angle clock input. The rising edge of CLK strobes all enabled registers. All timing specifications are referenced to the rising edge of CLK. |
| Inputs |  |  |  |
| B3-0 | A3, B3, A4, B4 | 42-39 | Parameter Register Address. The write addresses for the individual coordinate transform parameters are presented at the registered 4-bit B input port. B3 is the Most Significant Bit. |
| P11-0 | D10, D11, C10, C11, B11, B10, A10, B9, A9, B8, A8, B7 | 22-33 | Parameter Register Data. The coordinate transformation parameters are loaded through the registered 12-bit P input port. P11 is the Most Significant Bit. |
| Outputs |  |  |  |
| CA7-0 | $\begin{aligned} & \mathrm{K} 9, ~ L 8, ~ K 8, ~ L 7, ~ \\ & \text { K7, L6, K5, L4 } \end{aligned}$ | 7-2, 67, 66 | Coefficient Address. The current interpolation kernel coefficient lookup table address is indicated by the registered 8-bit CA7-0 output bus. This output is forced to the high impedance state when $\overline{\mathrm{NOOP}}$ is LOW. CA7 is the Most Significant Bit. |
| $\mathrm{U}_{11-0}$ | $\begin{gathered} \text { L2, K2, J1, J2, } \\ \text { H1, H2, G1, } \\ \text { G2, F1, E1, } \\ \text { E2, D1 } \end{gathered}$ | $\begin{gathered} 62,61,59-53 \\ 51-49 \end{gathered}$ | Target Address. The U (or V ) target address of the image being generated is indicated by the registered 12-bit U11-0 output bus. This output is forced to the high impedance state when $\overline{\text { OETA }}$ is HIGH. U11 is the Most Significant Bit. |
| $\mathrm{X}_{11-0}$ | $\begin{gathered} \text { E11, E10, F11, } \\ \text { G11, G10, } \\ \text { H11, H10, J11, } \\ \text { J10, K11, K10, } \\ \text { L9 } \end{gathered}$ | $\begin{gathered} 21-19,17-10, \\ 8 \end{gathered}$ | Source Address. The current X (or Y ) source pixel address of the image being resampled is indicated by the registered 12-bit $\mathrm{X}_{11-0}$ output bus. This output is forced to the high impedance state when $\overline{\text { NOOP }}$ is LOW. $\mathrm{X}_{11}$ is the Most Significant Bit. |
| Controls |  |  |  |
| $\overline{\text { ACC }}$ | L3 | 64 | Accumulate. The accumulation register of the external multiplieraccumulator is initialized by the registered $\overline{\mathrm{ACC}}$ output. $\overline{\mathrm{ACC}}$ goes LOW for one cycle at the start of each interpolation "walk," effectively clearing the storage register by loading in only the new first product. See Figure 9. |
| INIT | B2 | 44 | Initialize. The control logic is cleared and initialized for the start of a new image transformation when the registered INIT input is HIGH for a minimum of two clock cycles. Normal operation begins after INIT goes LOW. |
| INTER | C2 | 46 | Interconnect. In the common two-device system configuration, the Interconnect inputs are connected to the END flag outputs. The END flag from the row $(X)$ sequencer thus indicates an "end of line" to the column $(\mathrm{Y})$ device, while the column sequencer in turn sends a "bottom of frame" signal to the row device, forcing a reset of the address counter. |

## Pin Descriptions (continued)

| Pin Name | Pin Number |  | Pin Function Description |
| :---: | :---: | :---: | :---: |
|  | PGA | PLCC |  |
| LDR | A5 | 38 | Load Parameter Data Registers. The data held in all transformation parameter preload registers are latched into the working registers when the registered input LDR is HIGH. When LDR is LOW, the working parameters remain unchanged. See Figure 4. |
| $\overline{\mathrm{NOOP}}$ | B5 | 37 | No Operation. The Clock is overidden when the registered input NOOP is LOW, holding each address generator in their current state. Also, the output buffers for the address busses $\mathrm{X}_{11-0}$ and CA7-0 are forced to the high impedance state. This allows the user access to all external memory. When NOOP goes HIGH, normal operation resumes on the next clock cycle. |
| OETA | B1 | 45 | Target Memory Output Enable. The target memory outputs UWRI and address bus $U_{11-0}$ are in the high-impedance state when the registered Output Enable input is HIGH. When OETA is LOW, they are enabled on the next clock cycle. |
| UWRI | K3 | 63 | Target Memory Write Enable. After the end of each interpolation "walk," the Target Memory (U or V) Write Enable goes LOW for one clock cycle. See Figure 9. This registered output is forced to the high impedance state when OETA is HIGH. |
| WEN | A2 | 43 | Parameter Write Enable. The registered Write Enable input allows the transformation parameters to be written into the preload register indicated by the address at the B input port when LOW. See Figure 4. |
| Flags |  |  |  |
| $\overline{\text { CZERO }}$ | K4 | 65 | Coefficient Zero. The registered CZERO flag of a horizontal dimension TMC2301 goes HIGH if $X<0, X M I N \leq X \leq X M A X$, or $X \geq 4096$ (1000 hex). It goes LOW if $0 \leq X \leq X$ MIN or XMAX $<X<$ 4096. The logical AND of the CZERO flags of a two-dimensional pair of TMC2301s will go LOW when the source address falls outside a rectangle with vertices (XMIN, YMIN), (XMAX, YMIN), (XMIN, YMAX), and (XMAX, YMAX), denoting an invalid address. The external data path can be wired to substitute a selected background value whenever this AND $=0$. |
| DONE | D2 | 48 | End of Transform. In the standard two-device system, a row sequencer DONE flag HIGH after the last walk at the end of the last row of an image (during UWRI LOW) indicates the end of the transform. This registered output is usually ignored on the column device. See the Transformation Control Parameters, AUTOINIT. |
| END | C1 | 47 | End of Row/Page. The registered END flag goes HIGH during the last pixel of the last walk in a row in the case of the row chip, and the last pixel of the last walk in a column in the column chip, in the two-device architecture. This output is used as the end-ofline and end-of-frame indicator in conjunction with the INTER inputs of both TMC2301s. |

## Transformation Control Parameters

The TMC2301 is a self-sequencing device which requires no cycle-to-cycle intervention from the host system. To program the device, the user loads the 16 operating parameters, which define the transformation to be performed, which sections of the original and resampled image spaces are to be utilized, and various control words. Filtering operations are further defined by the values the user loads into the external coefficient memory. The transform parameters are described below. See also Tables 1 through 3.
\(\left.$$
\begin{array}{|l|l|}\hline \text { XMIN, XMAX, } \\
\text { YMIN, YMAX } & \begin{array}{l}\text { These four parameters outline the } \\
\text { "source" rectangular region of the } \\
\text { original image. Whenever the IRS } \\
\text { pair generates an (X, Y) address } \\
\text { within this boundary the CZERO } \\
\text { flags will denote a valid memory } \\
\text { read. In the most common case, } \\
\text { XMIN < XMAX, YMIN < YMAX, 000h } \\
\text { < X < FFFh, and 000h < Y< FFFh. In } \\
\text { this case, addresses out of bounds } \\
\text { cause one or both CZEROs to go } \\
\text { LOW. Refer to Application Note }\end{array} \\
& \begin{array}{l}\text { TP-38 for further information on other } \\
\text { boundary violation cases. Each } \\
\text { parameter is expressed in 12-bit } \\
\text { unsigned binary integer notation. } \\
\text { See Figure 12. }\end{array} \\
\hline \text { UMIN, } & \begin{array}{l}\text { These four parameters outline the } \\
\text { "target" region of the (u, v) plane, into } \\
\text { which the resampled image will be } \\
\text { written. The IRS will generate, line by } \\
\text { line, a scan that fills only this portion } \\
\text { of the plane, permitting the user to } \\
\text { assemble a mosaic of multiple }\end{array}
$$ <br>
VMIN, VMAX <br>
rectangular subimages. Care must <br>

be taken to ensure that UMAX >\end{array}\right\}\)| UMIN and VMAX > VMIN. Each |
| :--- |
| parameter is expressed in 12-bit |
| unsigned binary integer notation. |
| See Figure 12. |


| $\mathrm{dX} / \mathrm{dU} 0$ | Is the initial horizontal partial first derivative indicating the displacement along the X axis which corresponds to each one pixel movement along the $U$ axis. Usually, $0<\mathrm{dX} / \mathrm{dU} 0<1$ corresponds to magnification, whereas $\mathrm{dX} / \mathrm{dU} 0>1$ represents reduction and $\mathrm{dX} / \mathrm{dU} 0<0$ denotes reflection about a vertical axis. The first derivatives are expressed in 8-bit integer, 12-bit fraction two's complement notation. |
| :---: | :---: |
| $\mathrm{dX} / \mathrm{dV} 0$ | Is the initial horizontal-vertical partial first derivative. It indicates the displacement along the X axis corresponding to each one pixel movement along the V axis. The coefficients $\mathrm{dX} / \mathrm{dV}_{0}$ and $\mathrm{dX} / \mathrm{dU}_{0}$ define image rotation and shear. |
| $\mathrm{dY} / \mathrm{dU} 0$ | Is the initial vertical-horizontal partial first derivative. It indicates the displacement along the Y axis corresponding to each one pixel movement along the U axis. |
| $\mathrm{dY/dV} 0$ | Is the initial vertical partial first derivative. It indicates the displacement along the Y axis corresponding to each one-pixel step along the $V$ axis. Since $d X / d V_{0}$ and $\mathrm{dY} / \mathrm{dV} 0$ are separate parameters, vertical magnification and reflection need not match their horizontal counterparts. |

## Note:

1. For each incremental move along the $U$ axis, the starting point of the new "walk around spiral" is indexed to the ENDING point of the previous walk around spiral, rather than to its center. Therefore, the terms $\mathrm{dX} / \mathrm{d} \mathrm{U}_{0}$ and $\mathrm{dY} / \mathrm{dU} 0$ must be adjusted accordingly. Since each new line is referenced back to the previous line's initial spiral starting point, no similar $d X / d V_{0}$ or $d Y / d V_{0}$ correction is needed.

| $\mathrm{d}^{2} \mathrm{X} / \mathrm{dU} \mathrm{V}^{2}$ | Is the second order horizontal <br> derivative. It indicates the rate of <br> change of the horizontal-horizontal <br> first derivative with each step along a <br> line in the output image space. All six <br> second-order derivatives are 4-bit <br> integer, 20-bit fractional two's <br> complement parameters. |
| :--- | :--- |
| $\mathrm{d}^{2} \mathrm{X} / \mathrm{dV}^{2}$ | Is the second order horizontal- <br> vertical-vertical derivative. It <br> indicates the rate of change of the <br> horizontal-vertical first derivative with <br> each step down a column in the <br> output image space. |


| $\mathrm{d}^{2} \mathrm{Y} / \mathrm{dU}{ }^{2}$ | Is the second order vertical-horizontal-horizontal derivative. It indicates the rate of change of the the vertical-horizontal first derivative with each step along a line of the output image space. |  |
| :---: | :---: | :---: |
| $\mathrm{d}^{2} \mathrm{Y} / \mathrm{dV}^{2}$ | Is the second order vertical derivative. It indicates the rate of change of the vertical-vertical first derivative with each step down a column of the output image space. |  |
| $\mathrm{d}^{2} \mathrm{X} / \mathrm{dUdV}$ | Is the mixed second order derivative indicating the rate of change of the first order horizontal derivative as one proceeds downwards through the output image space. This is also the rate of change of the first order horizontal-vertical derivative during horizontal sweeps in the output image space. |  |
| $\mathrm{d}^{2} \mathrm{Y} / \mathrm{dUdV}$ | Is the mixed second order derivative indicating the rate of change of the first order vertical derivative as one moves horizontally across the output space, or, equivalently, the rate of change of the first order verticalhorizontal derivative as one moves vertically in the output image space |  |
| Row/Column Select | Sets the mode to either Row (0) or Column (1) operation. |  |
| Mode | This 2-bit control word defines three unique instructions: |  |
|  | Code | Instruction |
|  | $\begin{aligned} & 00,01 \\ & 10 \\ & 11 \end{aligned}$ | single-pass operation pass 1 of two-pass operation pass 2 of two pass operation |

In single-pass operation, the device walks through the entire $(k+1) x(k+1)$ kernel for each output pixel, where $k$ is the value written into the Kernel section (see below) of the parameter register. Two-pass operation, which requires a dimensionally separable kernel, is executed first for a $(k+1)$ element kernel in one direction, then for a $(\mathrm{k}+1)$ element kernel in the other direction. For kernel sizes exceeding $2 \times 2$, the two-pass algorithm is obviously beneficial, requiring 2 n samples per output point instead of nx n . In this case, the intermediate image data stored in the destination image memory following the first pass is used as the source image data on the second pass. The user may design a system to
switch source and destination memory bank addresses in place, or could utilize a second TMC2301 pair in a pipelined architecture. This would require a third image buffer for the final destination image. Both devices of a system pair are usually set to the same mode.

| Kernel | The effective kernel width (height) exceeds this 4 -bit unsigned number by 1 , thereby providing kernels of $1 \times 1$ to $16 \times 16$ source pixels per output, for either resampling or filtering. Simple static filters can be implemented with kernels of up to $16 \times 16$ pixels (Kernel $=$ 15), while resampling interpolation kernels are limited to $4 \times 4$ pixels (Kernel $=3$ ), due to the four bits of fractional $X$ (or Y) address generated by the TMC2301. See the Applications Discussion. Again, both devices in a pair are generally initialized with equal Kernel values. |
| :---: | :---: |
| Field of View (FOV) | As the device walks through its kernel coefficients, each corresponding step in ( $x, y$ ) space is normally one pixel length or height; this is a field of view of 1 . However, the user can subsample the original space before filtering or resampling, by applying the coefficient kernel over a view field of up to 7 units. At a field of view of $F$, the pixels selected for each kernel operation are F pixels apart. This is useful in oversampled pictures, whose intensity changes only slowly from pixel to pixel. |
| Autoload (ALR) | When set to 1 (HIGH), the LDR control is automatically asserted when INIT is strobed, loading the coefficient set currently stored in the preload registers. |
| Autoinit (AIN) | At the end of an image, if the AIN bit is 1 (HIGH) the DONE flag goes HIGH for one clock cycle and a new transform begins. If 0 (LOW), UWRI and the DONE flag remain HIGH during the sequence until the user strobes the INIT control to begin a new image transformation. |
| Pipe (PIPE) | Adjusts the timing of the target memory write controls, to compensate for buffered source image RAM. If the PIPE bit is $1(\mathrm{HIGH})$, outputs $\overline{\mathrm{ACC}}$ and $\overline{\mathrm{UWRI}}$ will be delayed one clock cycle relative to the generation of the target address (U or V). See Figure 9. |


| Test <br> Mode <br> (TM) | This mode is available for user inspection <br> of the coefficient data. The source image <br> and coefficient addresses are calculated <br> by an internal 28-bit accumulator. When <br> TM is 1 (HIGH), the sign bit, normally <br> discarded, and the lower 11 bits of <br> internal data are substituted for the upper <br> 12 bits appearing at the source address <br> port (X) during a standard transform <br> cycle. This allows user verification of <br> algorithm mathematics during debug. <br> Since the TM bit is registered and cannot <br> be changed during a single clock cycle, <br> two distinct clock cycles are required to <br> access both the MSW and LSW of the <br> internal accumulator. See Figure 3. |
| :--- | :--- |

Table 1. Parameter Registers - Row Sequencer

| Addr | Name | Description |
| :---: | :---: | :---: |
| 0000 | XMIN | Left side of Source Window |
| 0001 | XMAX | Right side of Source Window |
| 0010 | X0 (LSW) | Source starting point X coordinate |
| 0011 | X0 (MSW) | Source starting point X coordinate |
| 0011 | Controls | Mode Select Bits |
| 0100 | dX/dU0 (LSW) | Row/Row first differential |
| 0101 | dX/dU0 (MSW) | Row/Row first differential |
| 0101 | TM, FOV | Test Mode, Field of View |
| 0110 | $\mathrm{dX/dV} 0$ (LSW) | Row/Column first differential |
| 0111 | $\mathrm{dX} / \mathrm{d} \mathrm{V}_{0}$ (MSW) | Row/Column first differential |
| 0111 | Kernel | Resampling/Filtering Kernel |
| 1000 | $\begin{aligned} & \mathrm{d}^{2} \mathrm{X} / \mathrm{dUdV} \\ & (\mathrm{LSW}) \end{aligned}$ | Mixed second differential |
| 1001 | $\begin{aligned} & \mathrm{d}^{2} \mathrm{X} / \mathrm{dUdV} \\ & \text { (MSW) } \end{aligned}$ | Mixed second differential |
| 1010 | $\mathrm{d}^{2} \mathrm{X} / \mathrm{dU}{ }^{2}$ (LSW) | Row second differential |
| 1011 | $\mathrm{d}^{2} \mathrm{X} / \mathrm{dU}{ }^{2}$ (MSW) | Row second differential |
| 1100 | $\mathrm{d}^{2} \mathrm{X} / \mathrm{dV}^{2}(\mathrm{LSW})$ | Row/Column second differential |
| 1101 | $\mathrm{d}^{2} \mathrm{X} / \mathrm{dV}{ }^{2}(\mathrm{MSW})$ | Row/Column second differential |
| 1110 | UMIN | Left edge of Final Image |
| 1111 | UMAX | Right edge of Final Image |



Figure 3. Test Mode Data Routing

Table 2. Parameter Registers - Column Sequencer

| Addr | Name | Description |
| :--- | :--- | :--- |
| 0000 | YMIN | Top of Source Window |
| 0001 | YMAX | Bottom of Source Window |
| 0010 | Yo (LSW) | Source starting point - <br> Y coordinate |
| 0011 | Yo (MSW) | Source starting point - <br> Y coordinate |
| 0011 | Controls | Mode Select Bits |
| 0100 | $\mathrm{dY/dU0}$ (LSW) | Column/Row first differential |
| 0101 | $\mathrm{dY/dU0}$ (MSW) | Column/Row first differential |
| 0101 | TM, FOV | Test Mode, field of View |
| 0110 | $\mathrm{dY/dV0} \mathrm{(LSW)}$ | Column/Column first <br> differential |
| 0111 | $\mathrm{dY/dV0} \mathrm{(MSW)}$ | Column/Column first <br> differential |
| 0111 | Kernel | Resampling/Filtering Kernel <br> Sure |
| 1000 | $\mathrm{~d}^{2} \mathrm{Y} / \mathrm{dUdV}(\mathrm{LSW})$ | Mixed second differential |
| 1001 | $\mathrm{~d}^{2} \mathrm{Y} / \mathrm{dUdV}(\mathrm{MSW})$ | Mixed second differential |
| 1010 | $\mathrm{~d}^{2} \mathrm{Y} / \mathrm{dU}{ }^{2}$ (LSW) | Column/Row second <br> differential |
| 1011 | $\mathrm{~d}^{2} \mathrm{Y} / \mathrm{dU}{ }^{2}$ (MSW) | Column/Row second <br> differential |
| 1100 | $\mathrm{~d}^{2} \mathrm{Y} / \mathrm{dV2}$ (LSW) | Column second differential |
| 1101 | $\mathrm{~d}^{2} \mathrm{Y} / \mathrm{dV}{ }^{2}$ (MSW) | Column second differential |
| 1110 | VMIN | Top edge of Final Image |
| 1111 | VMAX | Bottom edge of Final Image |

Table 3. Parameter Registers Binary Format (Row or Column Sequencer)

| Address | Format |  |  |  |  |  |  |  |  |  |  |  | Limits |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MSB LSB |  |  |  |  |  |  |  |  |  |  |  | Dec | Hex |
| 0000* | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ | $\begin{gathered} 4095 \\ 0 \end{gathered}$ | $\begin{aligned} & \text { FFF } \\ & 000 \end{aligned}$ |
| 0001* | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ | $\begin{gathered} 4095 \\ 0 \end{gathered}$ | $\begin{aligned} & \hline \text { FFF } \\ & 000 \end{aligned}$ |
| $\begin{aligned} & 0010 \\ & 0011 \end{aligned}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $\begin{gathered} 2^{0} \\ -2^{12} \end{gathered}$ | $\begin{aligned} & 2^{-1} \\ & 2^{11} \end{aligned}$ | $\begin{aligned} & 2^{-2} \\ & 2^{10} \end{aligned}$ | $\begin{aligned} & 2^{-3} \\ & 2^{9} \end{aligned}$ | $\begin{aligned} & 2^{-4} \\ & 2^{8} \end{aligned}$ | $\begin{aligned} & 2^{-5} \\ & 2^{7} \end{aligned}$ | $\begin{gathered} 4096-2^{-5} \\ -4096 \end{gathered}$ | $\begin{aligned} & \text { OFFF.F8 } \\ & \text { F000.00 } \end{aligned}$ |
| 0011 (Control) | ALR | AIN | PIPE | R/C | M1 | Mo |  |  |  |  |  |  |  |  |
| $\begin{aligned} & 0100 \\ & 0101 \end{aligned}$ | $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $\begin{aligned} & 2^{-5} \\ & -2^{7} \end{aligned}$ | $\begin{aligned} & 2^{-6} \\ & 2^{6} \end{aligned}$ | $\begin{aligned} & 2^{-7} \\ & 2^{5} \end{aligned}$ | $\begin{aligned} & 2^{-8} \\ & 2^{4} \end{aligned}$ | $\begin{aligned} & 2^{-9} \\ & 2^{3} \end{aligned}$ | $\begin{aligned} & 2^{-10} \\ & 2^{2} \end{aligned}$ | $\begin{gathered} 2^{-11} \\ 2^{1} \end{gathered}$ | $\begin{aligned} & 2^{-12} \\ & 2^{0} \end{aligned}$ | $\begin{gathered} 128-2^{-12} \\ -128 \end{gathered}$ | $\begin{aligned} & \text { 007F.FFF } \\ & \text { FF80.000 } \end{aligned}$ |
| $\begin{aligned} & \text { 0101* (TM, } \\ & \text { FOV) } \end{aligned}$ | TM | $2^{2}$ | $2^{1}$ | $2^{0}$ |  |  |  |  |  |  |  |  |  |  |
| $\begin{aligned} & 0110 \\ & 0111 \end{aligned}$ | $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $\begin{aligned} & 2^{-5} \\ & -2^{7} \end{aligned}$ | $\begin{aligned} & 2^{-6} \\ & 2^{6} \end{aligned}$ | $\begin{aligned} & 2^{-7} \\ & 2^{5} \end{aligned}$ | $\begin{aligned} & 2^{-8} \\ & 2^{4} \end{aligned}$ | $\begin{aligned} & 2^{-9} \\ & 2^{3} \end{aligned}$ | $\begin{gathered} 2^{-10} \\ 2^{2} \end{gathered}$ | $\begin{gathered} 2^{-11} \\ 2^{1} \end{gathered}$ | $\begin{gathered} 2^{-12} \\ 2^{0} \end{gathered}$ | $\begin{gathered} 128-2^{-12} \\ -128 \end{gathered}$ | $\begin{aligned} & \hline \text { 007F.FFF } \\ & \text { FF80.000 } \end{aligned}$ |
| 0111* <br> (Kernel) | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |  |  |  |  |  |  |  |  | $\begin{gathered} 15 \\ 0 \end{gathered}$ | $\begin{aligned} & f \\ & 0 \end{aligned}$ |
| $\begin{aligned} & 1000 \\ & 1001 \end{aligned}$ | $\begin{aligned} & 2^{-9} \\ & -2^{3} \end{aligned}$ | $\begin{gathered} 2^{-10} \\ 2^{2} \end{gathered}$ | $\begin{gathered} 2^{-11} \\ 2^{1} \end{gathered}$ | $\begin{gathered} 2^{-12} \\ 2^{0} \end{gathered}$ | $\begin{aligned} & 2^{-13} \\ & 2^{-1} \end{aligned}$ | $\begin{aligned} & 2^{-14} \\ & 2^{-2} \end{aligned}$ | $\begin{aligned} & 2^{-15} \\ & 2^{-3} \end{aligned}$ | $\begin{gathered} 2^{-16} \\ 2^{-4} \end{gathered}$ | $\begin{aligned} & 2^{-17} \\ & 2^{-5} \end{aligned}$ | $\begin{gathered} 2^{-18} \\ 2^{-6} \end{gathered}$ | $\begin{aligned} & 2^{-19} \\ & 2^{-7} \end{aligned}$ | $\begin{gathered} 2^{-10} \\ 2^{-8} \end{gathered}$ | $\begin{gathered} 8-2^{-20} \\ -8 \end{gathered}$ | 0007.FFFFF |
| $\begin{aligned} & 1010 \\ & 1011 \end{aligned}$ | $\begin{aligned} & 2^{-9} \\ & -2^{3} \end{aligned}$ | $\begin{gathered} 2^{-10} \\ 2^{2} \end{gathered}$ | $\begin{aligned} & 2^{-11} \\ & 2^{1} \end{aligned}$ | $\begin{gathered} 2^{-12} \\ 2^{0} \end{gathered}$ | $\begin{aligned} & 2^{-13} \\ & 2^{-1} \end{aligned}$ | $\begin{gathered} 2^{-14} \\ 2^{-2} \end{gathered}$ | $\begin{aligned} & 2^{-15} \\ & 2^{-3} \end{aligned}$ | $\begin{aligned} & 2^{-16} \\ & 2^{-4} \end{aligned}$ | $\begin{aligned} & 2^{-17} \\ & 2^{-5} \end{aligned}$ | $\begin{aligned} & 2^{-18} \\ & 2^{-6} \end{aligned}$ | $\begin{aligned} & 2^{-19} \\ & 2^{-7} \end{aligned}$ | $\begin{aligned} & 2^{-10} \\ & 2^{-8} \end{aligned}$ | $\begin{gathered} 8-2^{-20} \\ -8 \end{gathered}$ | 0007.FFFFF |
| $\begin{aligned} & 1100 \\ & 1101 \end{aligned}$ | $\begin{aligned} & 2^{-9} \\ & -2^{3} \end{aligned}$ | $\begin{gathered} 2^{-10} \\ 2^{2} \end{gathered}$ | $\begin{gathered} 2^{-11} \\ 2^{1} \end{gathered}$ | $\begin{gathered} 2^{-12} \\ 2^{0} \end{gathered}$ | $\begin{aligned} & 2^{-13} \\ & 2^{-1} \end{aligned}$ | $\begin{gathered} 2^{-14} \\ 2^{-2} \end{gathered}$ | $\begin{aligned} & 2^{-15} \\ & 2^{-3} \end{aligned}$ | $\begin{gathered} 2^{-16} \\ 2^{-4} \end{gathered}$ | $\begin{aligned} & 2^{-17} \\ & 2^{-5} \end{aligned}$ | $\begin{aligned} & 2^{-18} \\ & 2^{-6} \end{aligned}$ | $\begin{aligned} & 2^{-19} \\ & 2^{-7} \end{aligned}$ | $\begin{aligned} & 2^{-10} \\ & 2^{-8} \end{aligned}$ | $\begin{gathered} 8-2^{-20} \\ -8 \end{gathered}$ | 0007.FFFFFF |
| 1110* | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ | $\begin{gathered} 4095 \\ 0 \end{gathered}$ | $\begin{aligned} & \text { FF } \\ & 000 \end{aligned}$ |
| 1111* | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ | $\begin{gathered} 4095 \\ 0 \end{gathered}$ | $\begin{gathered} \hline \text { FF } \\ 000 \end{gathered}$ |

## Notes:

1.     * unsigned binary notation
2. A "-" indicates MSB is sign bit

Internal Bit Mapping (For parametric inputs, integers in table are bits of $P$, the input point)

|  | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ | $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Xout [11:0] |  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
| CADN [7:4] |  |  |  |  |  |  |  |  |  |  |  |  |  | 7 | 6 | 5 | 4 |
| XMAX, XMIN |  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
| Xo | 5 | 4 | 3 | 2 | 1 | 0 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| DX/DU, DX/DV |  |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 11 | 10 | 9 | 8 |
| $\begin{aligned} & \hline \mathrm{D}^{2} \mathrm{X} / \mathrm{DUDV}, \\ & \mathrm{D}^{2} \mathrm{X} / \mathrm{DU} \mathrm{U}^{2}, \\ & \mathrm{D}^{2} \mathrm{I} / \mathrm{DV}^{2} \\ & \hline \end{aligned}$ |  |  |  |  |  |  |  |  |  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 |


|  | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ | $2^{-10}$ | $2^{-11}$ | $2^{-12}$ | $2^{-13}$ | $2^{-14}$ | $2^{-15}$ | $2^{-16}$ | $2^{-17}$ | $2^{-18}$ | $2^{-19}$ | $2^{-20}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| XOUT [11:0] |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| CADN [7:4] |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XMAX, XMIN |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Xo | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| DX/DU, DX/DV | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{D}^{2} \mathrm{X} / \mathrm{DUDV}, \\ & \mathrm{D}^{2} \mathrm{X} / \mathrm{DU} \mathrm{D}^{2}, \\ & \mathrm{D}^{2} \mathrm{~K} / \mathrm{DV}^{2} \end{aligned}$ | 3 | 2 | 1 | 0 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

## Operation of the Transformation Parameter Registers

Numerous applications require the ability to update the coordinate transformation parameters "on the fly." Because the parameters are double-buffered, the user can load any or all of them into the preload registers without upsetting the operation in progress. Then LDR (load data registers) will update all transform parameters to the new values simultaneously. This feature is particularly valuable for "pin cushion" and "fish eye" transformations, or polar-to-rectangular conversions which cannot be performed with constant second derivatives. The Autoload function updates the preread registers at the beginning of a new image automatically. See the Transformation Control Parameters section. Note also that data can be loaded in to the registers while $\overline{\mathrm{NOOP}}$ is active (LOW).


Figure 4. Operation of LDR Control for Parameter Update

## Timing Diagram



1. ts and $\operatorname{tD}(E)$ are guaranteed to allow full speed operation in the standard two-device architecture. See text. 2. All outputs except END. See text.

## Equivalent Circuits and Transition Levels



Figure 5. Equivalent Input Circuit

Figure 6. Equivalent Output Circuit



1. All outputs except $\overline{\mathrm{CZERO}}, \overline{\mathrm{ACC}}, \mathrm{END}$ and DONE.

Figure 7. Transition Level for Three-State Output

Absolute Maximum Ratings (beyond which the device may be damaged) ${ }^{1}$

| Parameter | Min | Typ | Max | Unit |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | -0.5 |  | 7.0 | V |  |
| Input Voltage | -0.5 |  | VDD +0.5 | V |  |
| Output |  |  |  |  |  |
| Applied Voltage ${ }^{2}$ | -0.5 |  | VDD +0.5 | V |  |
| Forced Current ${ }^{3,4}$ | -1.0 |  | 6.0 | mA |  |
| Short Circuit Duration (single output in HIGH state to ground) |  |  | 1 | sec |  |
| Temperature |  |  | 130 | ${ }^{\circ} \mathrm{C}$ |  |
| Operating, Case | -60 |  | 175 | ${ }^{\circ} \mathrm{C}$ |  |
| Operating, Junction |  |  | 300 | ${ }^{\circ} \mathrm{C}$ |  |
| Lead Soldering (10 seconds) |  |  | 150 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage | -65 |  |  |  |  |

## Notes:

1. Absolute maximum ratings are limiting values applied individually while all other parameters are within specified operating conditions. Functional operation under any of these conditions is NOT implied.
2. Applied voltage must be current limited to specified range, and measured with respect to GND.
3. Forcing voltage must be limited to specified range.
4. Current is specified as conventional current flowing into the device.

## Operating Conditions

| Parameter |  | Temperature Range |  |  |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Standard |  |  | Extended |  |  |  |
|  |  | Min | Typ | Max | Min | Typ | Max |  |
| VDD | Supply Voltage | 4.75 | 5.0 | 5.25 | 4.5 | 5.0 | 5.5 | V |
| VIL | Input Voltage, Logic LOW |  |  | 0.8 |  |  | 0.8 | V |
| VIH | Input Voltage, Logic HIGH | 2.0 |  |  | 2.0 |  |  | V |
| IOL | Output Current, Logic LOW |  |  | 8.0 |  |  | 8.0 | mA |
| IOH | Output Current, Logic HIGH |  |  | -4.0 |  |  | -4.0 | mA |
| TA | Ambient Temperature, Still Air | 0 |  | 70 |  |  |  | ${ }^{\circ} \mathrm{C}$ |
| TC | Case Temperature |  |  |  | -55 |  | 125 | ${ }^{\circ} \mathrm{C}$ |

DC Characteristics within specified operating conditions ${ }^{1}$

| Parameter |  | Conditions | Temperature Range |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Standard | Extended |  |  |
|  |  | Min | Max | Min | Max |  |
| IDDQ | Supply Current, Quiescent |  | VDD = Max, VIN = OV |  | 5 |  | 5 | mA |
| IDDU | Supply Current, Unloaded |  | VDD $=$ Max, $\mathrm{f}=15 \mathrm{MHz}$ |  | 75 |  | 75 | mA |
| IIL | Input Current, Logic LOW | VDD $=$ Max, V IN $=0 \mathrm{~V}$ | -10 | 10 | -75 | 75 | $\mu \mathrm{A}$ |
| IIH | Input Current, Logic HIGH | VDD $=$ Min, VIN = VDD | -10 | 10 | -75 | 75 | $\mu \mathrm{A}$ |
| VOL | Output Voltage, Logic LOW | VDD = Min, IOL = Max |  | 0.4 |  | 0.4 | V |
| VOH | Output Voltage, Logic HIGH | VDD $=$ Min, $\mathrm{IOH}=\mathrm{Max}$ | 2.4 |  | 2.4 |  | V |
| IOZL | Hi-Z Output Leakage Current, Output LOW | $\mathrm{V} D \mathrm{D}=\mathrm{Min}, \mathrm{VIN}=0 \mathrm{~V}$ | -40 | 40 | -40 | 40 | $\mu \mathrm{A}$ |
| IOZH | Hi-Z Output Leakage Current, Output HIGH | VDD $=$ Min, VIN = VDD | -40 | 40 | -40 | 40 | $\mu \mathrm{A}$ |
| Ios | Short-Circuit Output Current ${ }^{2}$ | VDD = Max, Output HIGH, one pin to ground, one second duration max. |  | -100 |  | -100 | mA |
| Cl | Input Capacitance | $\mathrm{TA}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ |  | 10 |  | 10 | pF |
| Co | Output Capacitance | $\mathrm{TA}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ |  | 10 |  | 10 | pF |

Notes:

1. Actual test conditions may vary from those shown, but guarantee operation as specified.
2. Guaranteed but not tested.

## AC Characteristics within specified operating conditions

| Parameter |  | Conditions | Temperature Range |  |  |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Standard | Extended |  |  |
|  |  | -2 | -1 |  | Min | Max | Min | Max |  |
|  |  | Min | Max | Min |  |  |  |  | Max |  |
| tcy | Cycle Time |  | VDD = Min | 50 |  | 55 |  | 66 |  | 66 |  | ns |
| tPWL | Clock Pulse Width LOW |  | VDD $=$ Min | 20 |  | 22 |  | 25 |  | 30 |  | ns |
| tPWH | Clock Pulse Width HIGH |  | $\mathrm{V} D \mathrm{D}=\mathrm{Min}$ | 25 |  | 28 |  | 33 |  | 35 |  | ns |
| ts | Input Setup Time ${ }^{1}$ |  | 15 |  | 18 |  | 20 |  | 20 |  | ns |
| tH | Input Hold Time |  | 1 |  | 2 |  | 2 |  | 2 |  | ns |
| tH(1) | Input Hold Time, INTER |  | 8 |  | 10 |  | 10 |  | 10 |  | ns |
| tD | Output Delay ${ }^{2}$ | VDD $=$ Min, CLOAD $=40 \mathrm{pF}$ |  | 25 |  | 27 |  | 35 |  | 35 | ns |
| tD(E) | Output Delay, END ${ }^{1}$ | VDD $=$ Min, CLOAD $=10 \mathrm{pF}$ |  | 35 |  | 37 |  | 45 |  | 45 | ns |
| tho | Output Hold Time ${ }^{2}$ | VDD = Max, CLOAD $=40 \mathrm{pF}$ | 5 |  | 5 |  | 5 |  | 5 |  | ns |
| tho(E) | Output Hold Time, END | VDD $=$ Max, CLOAD $=10 \mathrm{pF}$ | 10 |  | 10 |  | 10 |  | 10 |  | ns |
| tDIS | Three-State Disable Delay | VDD $=$ Min, CLOAD $=40 \mathrm{pF}$ |  | 25 |  | 27 |  | 35 |  | 35 | ns |
| tENA | Three-State Enable Delay | VDD $=$ Min, CLOAD $=40 \mathrm{pF}$ | 25 |  | 27 |  | 35 |  | 35 |  | ns |

## Notes:

1. $\mathrm{ts}+\operatorname{tD}(E)=\mathrm{tCY}$ max.
2. Excluding output pin END.

## Applications Discussion

## Basic Operation

Each TMC2301 pair contains address controllers which execute patterns much like the following FORTRAN 3-level nested DO loop:

1. The inner loop is a clockwise outgoing spiral "walk" through the N -element coefficient kernel.
2. The middle loop is a left-to-right "scan" along each row of the output image space.
3. Finally, the outer loop is a top-to-bottom "scan" down each column of the output image space.

A typical one pass image transformation proceeds as follows:

1. The device pair outputs the addresses $\left(\mathrm{X}_{0}, \mathrm{Y}_{0}\right)$, which is the first point in the source image, and (CAX, CAY), the interpolation lookup table address for the first pixel in the kernel. The output $\overline{\text { ACC }}$ goes LOW, causing the
external accumulator to load the first product without summation, clearing the accumulator.
2. For the next N cycles, the IRS walks through an outward clockwise spiral in ( $\mathrm{x}, \mathrm{y}$ ) space, accumulating pixelinterpolation coefficient products. The spiral sequence is depicted in Figure 8.
3. After the completion of the first spiral walk, the IRS outputs the target address of the first pixel, (UMIN, VMIN) and the control UWRI, along with the initial (X, Y) values of the next spiral walk. $\overline{A C C}$ and $\overline{U W R I}$ can be delayed by one clock cycle by setting the control bit PIPE to 1 (HIGH) simplifying the task of interfacing the TMC2301 to buffered source image memory.
4. After the last cycle of the next spiral, $\overline{\mathrm{UWRI}}$ again goes LOW for one clock, and the target address outputs are updated, pointing to the location of the pixel calculation just completed, (UMIN + 1, VMIN).
5. The third spiral walk begins with $\overline{\text { ACC }}$ going LOW, and ends with (UMIN +2 , VMIN) output and UWRI going LOW.


Figure 8. Timing Diagram and Pixel Map Showing Outward Clockwise Spiral Walk Generated by TMC2301 (2x2 Kernel Shown)
6. The procedure continues until (UMAX $+1, \mathrm{VMIN}$ ) is reached, at which point the device resets to U (position within row) and increments V (number of row). Thus, the next ( $\mathrm{U}, \mathrm{V}$ ) set after (UMAX + 1, VMIN) will be (UMIN, VMIN +1 ), followed by (UMIN +1 , VMIN + 1), etc.
7. Upon completion of the walk corresponding to (UMAX $+1, \mathrm{VMAX}+1$ ), the TMC2301 will generate a DONE flag with the final $\overline{\text { UWRI, }}$, and begin a new sequence.

On any given clock cycle, the actual ( $\mathrm{X}, \mathrm{Y}$ ) and ( $\mathrm{U}, \mathrm{V}$ ) outputs of the IRS are given by the following equations:

$$
\begin{aligned}
\mathrm{x}= & \mathrm{X}_{0} \\
& +\mathrm{dX} / \mathrm{dU}_{0} * \mathrm{~m}+\mathrm{dX} / \mathrm{dV} 0 * \mathrm{n}+\mathrm{d}^{2} \mathrm{X} / \mathrm{dUdV} * \mathrm{~m} * \mathrm{n} \\
& +\mathrm{d}^{2} \mathrm{X} / \mathrm{dU}^{2} *(\mathrm{~m} 2-\mathrm{m}) / 2+\mathrm{d}^{2} \mathrm{X} / \mathrm{dV}^{2} *\left(\mathrm{n}^{2}-\mathrm{n}\right) / 2 \\
& +\mathrm{FOV} * \operatorname{CAX}(\mathrm{w})+\mathrm{FOV} * \mathrm{~m} * \operatorname{CAX}(\text { Ker }) \\
\mathrm{y}= & \mathrm{Y}_{0} \\
& +\mathrm{dY} / \mathrm{dU}_{0} * \mathrm{~m}+\mathrm{dX} / \mathrm{dV} 0 * \mathrm{n}+\mathrm{d}^{2} \mathrm{Y} / \mathrm{dUdV} * \mathrm{~m} * \mathrm{n} \\
& +\mathrm{d}^{2} \mathrm{Y} / \mathrm{dU}^{2} *(\mathrm{~m} 2-\mathrm{m}) / 2+\mathrm{d}^{2} \mathrm{Y} / \mathrm{dV}^{2} *\left(\mathrm{n}^{2}-\mathrm{n}\right) / 2 \\
& +\mathrm{FOV} * \operatorname{CAY}(\mathrm{w})+\mathrm{FOV} * \mathrm{~m} * \operatorname{CAY}(\text { Ker }) \\
\mathrm{u}= & \mathrm{UMIN}+\mathrm{m} \\
\mathrm{v}= & \mathrm{VMIN}+\mathrm{n}
\end{aligned}
$$

where FOV is the 4-bit field of view parameter, normally set to 1 so that the spiral walk proceeds in single-pixel steps. Setting FOV to 4 would expand the spiral walk, allowing the user to trade two bits of image size for two bits of additional interpixel positioning resolution. CAX(w) and CAY(w) are the current value of the coefficient address outputs and CAX (KER) and CAY(KER) are the terminal values of each pixel walk. The CA(KER) terms arise because the IRS computes each new walk's starting paint from the previous spiral walk's end point rather than its starting point.

## Interpolation Coefficient Lookup Table Addressing

The external coefficient lookup table RAM stores the interpolation values used to calculate the value of the new pixel. These values are selected by the user allowing maximum filtering flexibility. In simple filtering applications, all 8 bits of coefficient address are available to access up to 256 interpolation coefficients, for kernels of $16 \times 16$ pixels. This address is generated by the internal walk counter of the TMC2301. In most applications, the same Kernel parameter value is selected in both IRS devices; thus, the Coefficient Address outputs CA7-0 for the X and Y devices are identical, and the user needs only one of the 8 -bit buses for memory access.

Applications executing a coordinate transformation, however will almost always generate non-integer source pixel addresses; that is the U ( or V ) locations will not map to the X (or Y ) addresses exactly and fractional address components
are generated. The user then must account for this spatial offset in both dimensions by storing the appropriate corrected interpolation kernel values in the lookup table. The 8 -bit address bus is broken up into two parts: the fractional portion (upper 4 bits), and the walk counter (lower 4 bits). Thus, in resampling applications, the maximum kernel size is $4 \times 4$ pixels, or 16 locations. As in the filtering example, assuming that the user has selected the same kernel size for both IRS devices, the 4 bits of least-significant address generated by both devices will be identical and redundant. The four most significant address bits, however, will reflect the current fractional offsets of the resampled pixel from the nearest X (Y) location, to a spatial resolution of 4 bits in the X (or Y ) directions. Utilization of the 12 bits (total) of lookup table address is left to the user to be arranged as desired for memory access. See Figure 3.

## Application Examples

One of the more common applications for the TMC2301 is simple static filtering In this case the source and target memories locations are identical and no coordinate transformation is performed. The $(\mathrm{X}, \mathrm{Y})$ and $(\mathrm{U}, \mathrm{V})$ outputs listed in Table 4 show the address sequencing generated by the TMC2301 to execute the walk of a $5 \times 5$ pixel interpolation kernel. The normalized coefficients shown implement a firstorder Butterworth Low Pass Filter with cutoff radius of $1 / \sqrt{2}$. Note that the $(\mathrm{U}, \mathrm{V})$ output address is updated following the completion of the walk for that location.


Figure 9. Pixel Map Showing Walk Sequence for 5x5 Static Filter

Table 4. IRS Outputs for Static Filter Illustrated in Figure 10

| Cycle | $\mathbf{X}$ | $\mathbf{Y}$ | Index <br> (CA) | Coefficient | $\mathbf{U}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 3 | 4 | 0 | 0.2176 | 2 | 4 |
| 2 | 4 | 4 | 1 | 0.0725 | 2 | 4 |
| 3 | 4 | 5 | 2 | 0.0435 | 2 | 4 |
| 4 | 3 | 5 | 3 | 0.0725 | 2 | 4 |
| 5 | 2 | 5 | 4 | 0.0435 | 2 | 4 |
| 6 | 2 | 4 | 5 | 0.0725 | 2 | 4 |
| 7 | 2 | 3 | 6 | 0.0435 | 2 | 4 |
| 3 | 3 | 3 | 7 | 0.0725 | 2 | 4 |
| 9 | 4 | 3 | 8 | 0.0435 | 2 | 4 |
| 10 | 5 | 3 | 9 | 0.0198 | 2 | 4 |
| 11 | 5 | 4 | 10 | 0.0272 | 2 | 4 |
| 12 | 5 | 5 | 11 | 0.0198 | 2 | 4 |
| 13 | 5 | 6 | 12 | 0.0128 | 2 | 4 |
| 14 | 4 | 6 | 13 | 0.0198 | 2 | 4 |
| 15 | 3 | 6 | 14 | 0.0272 | 2 | 4 |
| 16 | 2 | 6 | 15 | 0.0198 | 2 | 4 |
| 17 | 1 | 6 | 16 | 0.0128 | 2 | 4 |
| 18 | 1 | 5 | 17 | 0.0198 | 2 | 4 |
| 19 | 1 | 4 | 18 | 0.0272 | 2 | 4 |
| 20 | 1 | 3 | 19 | 0.0198 | 2 | 4 |
| 21 | 2 | 2 | 20 | 0.0128 | 2 | 4 |
| 22 | 3 | 2 | 21 | 0.0198 | 2 | 4 |
| 23 | 4 | 2 | 22 | 0.0272 | 2 | 4 |
| 24 | 5 | 2 | 23 | 0.0198 | 2 | 4 |
| 25 | 4 | 2 | 24 | 0.0128 | 2 | 4 |
| 26 |  | 4 | 0 | 0.2175 | 3 | 4 |

Figure 10 illustrates the sequence for a bilinear resampling of a $63^{\circ}$ rotation. The starting point is translated +1 in the Y direction. A common rotation matrix might be:

$$
\begin{array}{ll}
\mathrm{dX} / \mathrm{dU}_{0}=\cos (\mathrm{a})=.6 & \mathrm{dY} / \mathrm{dU}_{0}=\sin (\mathrm{a})=.8 \\
\mathrm{dX} / \mathrm{dV} 0=-\sin (\mathrm{a})=-.8 & \mathrm{dY} / \mathrm{dV}_{0}=\cos (\mathrm{a})=.6
\end{array}
$$

However, we have included a linear compression factor of $5: 1$, and must accommodate the fact that each time $u$ is incremented, the start of the new walk is referenced to the END of the previous walk. Given these corrections, the rotation matrix becomes:

$$
\begin{array}{ll}
\mathrm{dX} / \mathrm{dU}_{0}=5 \cos (\mathrm{a})=3 & \mathrm{dY} / \mathrm{dU} \mathrm{U}_{0}=5 \sin (\mathrm{a})-\mathrm{FOV}=3 \\
\mathrm{dX} / \mathrm{dV} 0=5 \sin (\mathrm{a})=-4 & \mathrm{dY} / \mathrm{dV} V_{0}=5 \cos (\mathrm{a})=3 \\
\text { Kernel }=1 &
\end{array}
$$



Figure 10. Pixel Map Showing parameters for $63^{\circ}$ Rotation and 5:1 Compression Listed in Table 5

Table 5. IRS Outputs for Operation Illustrated in Figure 11

| Cycle | X | Y | Index | U | V |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 5 | 5 | 0 | 4 | 5 |
| 2 | 6 | 5 | 1 | 4 | 5 |
| 3 | 6 | 6 | 2 | 4 | 5 |
| 4 | 5 | 6 | 3 | 4 | 5 |
| 5 | 8 | 9 | 0 | 5 | 5 |
| 6 | 9 | 9 | 1 | 5 | 5 |
| 7 | 9 | 10 | 2 | 5 | 5 |
| 8 | 8 | 10 | 3 | 5 | 5 |
| 9 | 11 | 13 | 0 | 6 | 5 |
| 10 | 12 | 13 | 1 | 6 | 5 |
| 11 | 12 | 14 | 2 | 6 | 5 |
| 12 | 11 | 14 | 3 | 6 | 5 |
| 13 | 14 | 17 | 0 | 7 | 5 |
| 14 | 15 | 17 | 1 | 7 | 5 |
| 15 | 15 | 18 | 2 | 7 | 5 |
| 16 | 14 | 18 | 3 | 7 | 5 |
| 17 | 1 | 8 | 0 | 8 | 5 |
| 18 | 2 | 8 | 1 | 8 | 5 |
| 19 | 2 | 9 | 2 | 8 | 5 |
| 20 | 1 | 9 | 3 | 8 | 5 |
| 21 | 4 | 12 | 0 | 5 | 6 |
| 22 | 5 | 12 | 1 | 5 | 6 |
| 23 | 5 | 13 | 2 | 5 | 6 |
| 24 | 4 | 13 | 3 | 5 | 6 |
| 25 | 7 | 16 | 0 | 6 | 6 |
| 26 | 8 | 16 | 1 | 6 | 6 |
| 27 | 8 | 17 | 2 | 6 | 6 |
| 28 | 7 | 17 | 3 | 6 | 6 |
| 29 | 10 | 20 | 0 | 7 | 6 |
| 30 | 11 | 20 | 1 | 7 | 6 |
| 31 | 11 | 21 | 2 | 7 | 6 |
| 32 | 10 | 21 | 3 | 7 | 6 |
| 33 | 0 | 5 | 0 | 8 | 6 |

Figure 11 may help clarify the relationships among ( $\mathrm{X}_{0}, \mathrm{Y}_{0}$ ), (XMIN, YMIN), (XMAX, YMAX), (UMIN, VMIN), and (UMAX, VMAX). With positive first derivatives, ( $\mathrm{X}_{0}, \mathrm{Y}_{0}$ ) and (UMIN, VMIN) represent the upper left corners of the original image and the new destination field, respectively. The lower right corner of the transformed image is located at
(UMAX + 1, VMAX + 1); the location of the corresponding corner of the original image depends on the values of the derivatives. Not to be confused with ( $\mathrm{X}_{0}, \mathrm{Y}_{0}$ ), the points (XMIN, YMIN) and (XMAX, YMAX) define the "usable" rectangular portion of the original image; points ( $\mathrm{X}, \mathrm{Y}$ ) lying outside this region are ignored in most resampling and filtering applications. This feature permits one to construct a mosaic of several abutting subimages in the ( $\mathrm{x}, \mathrm{y}$ ) plane, without danger of edge effect interference between adjacent subimages. Note in the figure that the upper right and lower right corners of the resampled image lie outside the admissible region; in practice, the values fetched at these locations will not be included in the convolutional sums.


Note: Assume $000 \mathrm{~h}<\mathrm{X}<$ FFFh, $000 \mathrm{~h}<\mathrm{Y}<$ FFFh
65-2301-15

Figure 11. Pixel Maps Demonstrating Source and Destination Image Boundaries and Image Clipping (Note Shaded Area)

## Application Note

## Nearest Neighbor Operation—Additional Timing Details

## Example A, PIPE = 0

Inspecting Figure 13:
PIPE $=0, \mathrm{KER}=0$ (near neighbor), AUTOIN $=1$ (on), $\mathrm{UMN}=0, \mathrm{UMX}=5, \mathrm{VMN}=0, \mathrm{VMX}=5$,
$\mathrm{DX} / \mathrm{DU}=1, \mathrm{DY} / \mathrm{DV}=1, \mathrm{XO}=0$
First rising edge of CLK after INIT falling edge is \#0. Table entries are events after listed clock rising edge. END, DONE flags $=0$, except where shown as 1 . UWRI goes low and remains low with CLK \#2.

| CLK | X | U | V | END |  | DON | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | R | C |  |  |
| 0 |  |  |  | 0 | 0 |  | First clock after INIT falling edge |
| 1 |  |  |  | 0 | 0 |  |  |
| 2 | 0 |  |  | 0 | 0 |  | First valid X addresses $=\mathrm{XO}$ |
| 3 | 1 | 0 | 0 | 0 | 0 |  | Second $X$; first valid $U, V=U M N$, VMN |
| 4 | 2 | 1 | 0 | 0 | 0 |  |  |
| 5 | 3 | 2 | 0 | 1 | 0 |  | END ROW flag 3 cycles before last X |
| 6 | 4 | 3 | 0 | 0 | 0 |  |  |
| 7 | 5 | 4 | 0 | 0 | 0 |  |  |
| 8 | 6 | 5 | 0 | 0 | 0 |  | Last X of first row |
| 9 | 0 | 6 | 0 | 0 | 0 |  | Last U, V or first row; first X of 2nd row |
| 10 | 1 | 0 | 1 | 0 | 0 |  | First U, V of second row |
| 11 | 2 | 1 | 1 | 0 | 0 |  |  |
| 12 | 3 | 2 | 1 | 1 | 0 |  | END ROW flag 4 cycles before last U, V |
| 13 | 4 | 3 | 1 | 0 | 0 |  |  |
| 14 | 5 | 4 | 1 | 0 | 0 |  |  |
| 15 | 6 | 5 | 1 | 0 | 0 |  | Last X of second row |
| 16 | 0 | 6 | 1 | 0 | 0 |  | Last U, V of second row $U=U M X+1$ |
| 35 | 5 | 4 | 4 | 0 | 1 |  | END COL goes high before last X |
| 36 | 6 | 5 | 4 | 0 | 1 |  | Last X of $\mathrm{V}=\mathrm{VMX}-1$ row |
| 37 | 0 | 6 | 4 | 0 | 1 |  | First X of Last ( $\mathrm{V}=\mathrm{VMX}$ ) row |
| 38 | 1 | 0 | 5 | 0 | 1 |  | First $\mathrm{U}, \mathrm{V}=\mathrm{UMN}, \mathrm{VMX}$ of last now |
| 39 | 2 | 1 | 5 | 0 | 1 |  |  |
| 40 | 3 | 2 | 5 | 1 | 1 |  | Last END ROW flag of frame |
| 41 | 4 | 3 | 5 | 0 | 1 |  | END COL goes low when DONE goes high |
| 42 | 5 | 4 | 5 | 0 | 0 | 1 | DONE immediately before last X |
| 43 | 6 | 5 | 5 | 0 | 0 |  | Last X of frame |
| 44 | 0 | 6 | 5 | 0 | 0 |  | Last $\mathrm{U}, \mathrm{V}=\mathrm{UMX}+1, \mathrm{VMX}$ |
| 45 | 1 | 0 | 0 | 0 | 0 |  | First $\mathrm{U}, \mathrm{V}=\mathrm{UMN}, \mathrm{VMN}$ of new frame |
| 46 | 2 | 1 | 0 | 0 | 0 |  |  |
| 47 | 3 | 2 | 0 | 1 | 0 |  | First END ROW flag of new frame |

Example B, PIPE = 1
Now, referring to Figure 14:
PIPE $=1$, KER $=0$ (near neighbor), AUTOIN = 1 (on),
$\mathrm{UMN}=0, \mathrm{UMX}=5, \mathrm{VMN}=0, \mathrm{VMX}=5$,
$\mathrm{DX} / \mathrm{DU}=1, \mathrm{DY} / \mathrm{DV}=1, \mathrm{XO}=0$
First rising edge of CLK after INIT falling edge is \#0.
Table entries are events after listed clock rising edges.
END, DONE, flags $=0$, except where shown as 1 .
UWRI goes low with CLK \#3, stays low. Otherwise, the timing is the same as Figure 13, i.e., pipeline delays UWRI and ACC by one clock cycle.

## Bilinear Interpolation

Example C, PIPE = 0
From Figure 15, we can see the following:
PIPE $=0, \mathrm{KER}=1$ (bilinear), $\mathrm{AUTOIN}=1$ (on),
$\mathrm{UMN}=0, \mathrm{UMX}=5, \mathrm{VMN}=0, \mathrm{VMX}=5$,
$\mathrm{DX} / \mathrm{DU}=1, \mathrm{DY} / \mathrm{DV}=1, \mathrm{YO}=0, \mathrm{XO}=0$
First rising edge of CLK after INIT falling edge is \#0.
Table entries are events after listed clock rising edges.
END, DONE flags $=0$, except where shown as 1 .

| CLK | X | U | V | $\begin{aligned} & \text { END } \\ & \text { ROW } \end{aligned}$ | UWR | ACC | DON | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 |  |  |  |  | 1 | 0 |  | 1st CLK after INIT falling edge |
| 1 |  |  |  |  | 0 | 0 |  |  |
| 2 | 0 |  |  |  | 1 | 0 |  | 1st valid $X$ address $=$ XO: start 1st ACCum |
| 3 | 1 |  |  |  | 0 | 1 |  |  |
| 4 | 1 |  |  |  | 1 | 1 |  |  |
| 5 | 0 |  |  |  | 1 | 1 |  | End 1st 2x2 kernel; end 1st ACCum |
| 6 | 1 | 0 | 0 |  | 1 | 0 |  | 1st valid $u, v=U M N$, VMN; 2nd ACCum start |
| 7 | 2 | 0 | 0 |  | 0 | 1 |  |  |
| 8 | 2 | 0 | 0 |  | 1 | 1 |  |  |
| 9 | 1 | 0 | 0 |  | 1 | 1 |  |  |
| 10 | 2 | 1 | 0 |  | 1 | 0 |  | 2nd valid $u, v=$ UMN + 1, VMN |
| 11 | 3 | 1 | 0 |  | 0 | 1 |  |  |
| 12 | 3 | 1 | 0 |  | 1 | 1 |  |  |
| 13 | 2 | 1 | 0 |  | 1 | 1 |  |  |
| 14 | 3 | 2 | 0 |  | 1 | 0 |  | 3rd valid $u, v=$ UMN + 2, VMN |
| 15 | 4 | 2 | 0 |  | 0 | 1 |  |  |
| 16 | 4 | 2 | 0 |  | 1 | 1 |  |  |
| 17 | 3 | 2 | 0 |  | 1 | 1 |  | End 4th 2x2 kernel |
| 160 | 5 | 3 | 5 | 1 | 1 | 1 |  |  |
| 161 | 4 | 3 | 5 | 1 | 1 | 1 |  |  |
| 162 | 5 | 4 | 5 | 1 | 1 | 0 |  | Begin next-to-last x-walk |
| 163 | 6 | 5 | 4 | 1 | 0 | 1 |  |  |
| 164 | 6 | 5 | 4 |  | 1 | 1 |  |  |


| CLK | $\mathbf{X}$ | $\mathbf{U}$ | $\mathbf{V}$ | END <br> ROW | UWR | ACC | DON | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 165 | 5 | 4 | 5 |  | 1 | 1 |  |  |
| 166 | 6 | 5 | 5 |  | 1 | 0 |  | Begin last $x$-walk |
| 167 | 7 | 5 | 5 |  | 0 | 1 |  |  |
| 168 | 7 | 5 | 5 |  | 1 | 1 | 1 |  |
| 169 | 6 | 5 | 5 |  | 1 | 1 |  | Last $x$ of frame |
| 170 | 0 | 6 | 5 |  | 1 | 0 |  |  |
| 171 | 1 | 6 | 5 |  | 0 | 1 |  |  |
| 172 | 1 | 6 | 5 |  | 1 | 1 |  |  |
| 173 | 0 | 6 | 5 |  | 1 | 1 |  | Last $u, v=$ UMX +1, <br> VMX |
| 174 | 1 | 0 | 0 |  | 1 | 0 |  | First $u, v$ of new <br> frame |
| 175 | 2 | 0 | 0 |  | 0 | 1 |  |  |
| 176 | 2 | 0 | 0 |  | 1 | 1 |  |  |
| 177 | 1 | 0 | 0 |  | 1 | 1 |  |  |

## Performing Larger Interpolation Kernels

With PIPE $=0$, AUTOINIT $=1$, and the following definitions:
$\mathrm{T}_{\mathrm{xd} \text { done }}=$ Clock cycle of final X address of a transform.
$\mathrm{T}_{\mathrm{xend}}=$ Clock cycle of final X address along a row.
KER $=(\mathrm{K}+1)(\mathrm{K}+1)$, where K is the value in the "kernel size" parameter register.

The following relationships hold true:
First $X$ address valid 3 rising clock edges after INITs failing edge.

END FLAG
goes HIGH for KER cycles at clock cycle Txend $-1-2 *$ KER. Otherwise stated, END is active for one walkaround starting two walkarounds and one cycle prior to the final source address of a row.

DONE FLAG
goes HIGH for one cycle at clock cycle $\mathrm{T}_{\mathrm{x} \text { done }}-1$. Otherwise stated, DONE is active for one clock cycle one cycle prior to the last source address of the final walkaround.

Example D, KER = 0 (nearest neighbor), UMIN = 0, UMAX $=3, \operatorname{UMIN}=0$, VMAX $=2$
If first CLOCK edge after INIT goes low is 0 , then:
First x , y out ( $=\mathrm{XO}, \mathrm{YO}$ ) appears after CLOCK edge 2.
First $u$, $v$ out $(=0,0)$ appears after CLOCK edge 3.
END is high after CLOCK edge 13 only.
DONE is high after CLOCK edge 16.
Last x out appears after CLOCK edge 16.
Last $u$, $v$ out $(=4,2)$ appears after CLOCK edge 17.
Example E, KER = 1, ( 1 pass bilinear), $\mathrm{UMIN}=0$, UMAX $=4, \mathrm{VMIN}=1, \mathrm{VMAX}=3$
If first CLOCK edge after INIT goes low is 0 , then:
First x , y out (=XO, YO) appears after CLOCK edge 2.
First $u$, $v$ out $(=0,1)$ appears after CLOCK edge 6 and remains through edges 7,8 and 9 .
END is high after CLOCK edge 92, goes low after 96.
DONE is high after CLOCK edge 100 only.
Last x out appears CLOCK edge 101.
Last $u$, $v$ out $(=5,3)$ appears after CLOCK edge 102 and remains through edges 103, 104 and 105.


Figure 12.


Figure 13.


Figure 14

## Notes:

## Notes:

## Mechanical Dimensions

## 68 Lead Pin Grid Array

| Symbol | Inches |  | Millimeters |  | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min. | Max. | Min. | Max. |  |
| A | . 080 | . 125 | 2.03 | 3.18 |  |
| A1 | . 040 | . 060 | 1.02 | 1.52 |  |
| A2 | . 115 | . 190 | 2.92 | 4.83 |  |
| $\oplus$ B | . 017 | . 020 | 0.43 | 0.51 |  |
| øB2 | . 050 NOM. |  | 1.27 NOM. |  |  |
| D | 1.140 | 1.180 | 28.96 | 29.97 |  |
| D1 | 1.000 BSC |  | 25.40 BSC |  |  |
| e | . 100 BSC |  | 2.54 BSC |  |  |
| L | . 120 | . 140 | 3.05 | 3.56 |  |
| M | 11 |  | 11 |  | 2 |
| N | 68 |  | 68 |  | 3 |
| P | . 003 | - | . 076 | - |  |

## Notes:

1. Pin \#1 identifier shall be within shaded area shown.
2. Dimension " M " defines matrix size.
3. Dimension "N" defines the maximum possible number of pins.
4. Controlling dimension: inch.
5. Optional index pin.


Mechanical Dimensions (continued)

## 68 Lead Plastic Leaded Chip Carrier

| Symbol | Inches |  | Millimeters |  | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min. | Max. | Min. | Max. |  |
| A | . 165 | . 200 | 4.19 | 5.08 |  |
| A1 | . 090 | . 130 | 2.29 | 3.30 |  |
| A2 | . 020 | - | . 51 | - |  |
| B | . 013 | . 021 | . 33 | . 53 |  |
| B1 | . 026 | . 032 | . 66 | . 81 |  |
| D/E | . 985 | . 995 | 25.02 | 25.27 |  |
| D1/E1 | . 950 | . 958 | 24.13 | 24.33 | 3 |
| D3/E3 | . 800 BSC |  | 20.32 BSC |  |  |
| e | . 050 BSC |  | 1.27 BSC |  |  |
| J | . 042 | . 056 | 1.07 | 1.42 | 2 |
| ND/NE | 17 |  | 17 |  |  |
| N | 68 |  | 68 |  |  |
| ccc | - | . 004 | - | 0.10 |  |

## Notes:

1. All dimensions and tolerances conform to ANSI Y14.5M-1982
2. Corner and edge chamfer $(\mathrm{J})=45^{\circ}$
3. Dimension D1 and E1 do not include mold protrusion. Allowable protrusion is .101 " (.25mm)


## Ordering Information

| Product Number | Temperature Range | Screening | Package | Package Marking |
| :--- | :--- | :---: | :---: | :---: |
| TMC2301G8C | STD-TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Commercial | 68 Pin Grid Array | $2301 \mathrm{G8C}$ |
| TMC2301G8C1 | STD-TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Commercial | 68 Pin Grid Array | $2301 \mathrm{G8C} 1$ |
| TMC2301G8C2 | STD-TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Commercial | 68 Pin Grid Array | $2301 \mathrm{G8C} 2$ |
| TMC2301G8A | EXT-TC $=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | Hi Rel | 68 Pin Grid Array | $2301 \mathrm{G8A}$ |
| TMC2301G8A1 | EXT-TC $=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | Hi Rel | 68 Pin Grid Array | $2301 \mathrm{G8A} 1$ |
| TMC2301H8C | STD-TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Commercial | 68 Pin Grid Array | $2301 \mathrm{H8C}$ |
| TMC2301H8C1 | STD-TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Commercial | 68 Pin Grid Array | $2301 \mathrm{H8C1}$ |
| TMC2301H8C2 | STD-TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Commercial | 68 Pin Grid Array | $2301 \mathrm{H8C2}$ |
| TMC2301L1A | EXT-TC $=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | Hi Rel | 68 Leaded Hermetic <br> Ceramic Chip Carrier | 2301 L 1 A |
| TMC2301L1A1 | EXT-TC $=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | Hi Rel | 68 Leaded Hermetic <br> Ceramic Chip Carrier | 2301 L 1 A 1 |
| TMC2301R1C | STD-TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Commercial | 68 Lead Plastic J-Leaded <br> Chip Carrier | $2301 \mathrm{R1C}$ |
| TMC2301R1C1 | STD TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Commercial | 68 Lead Plastic J-Leaded <br> Chip Carrier | $2301 \mathrm{R1C1}$ |
| TMC2301R1C2 | STD-TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Commercial | 68 Lead Plastic J-Leaded <br> Chip Carrier | $2301 \mathrm{R1C2}$ |

The information contained in this data sheet has been carefully compiled; however, it shall not by implication or otherwise become part of the terms and conditions of any subsequent sale. Raytheon's liability shall be determined solely by its standard terms and conditions of sale. No representation as to application or use or that the circuits are either licensed or free from patent infringement is intended or implied. Raytheon reserves the right to change the circuitry and any other data at any time without notice and assumes no liability for errors.

## LIFE SUPPORT POLICY:

Raytheon's products are not designed for use in life support applications, wherein a failure or malfunction of the component can reasonably be expected to result in personal injury. The user of Raytheon components in life support applications assumes all risk of such use and indemnifies Raytheon Company against all damages.

Raytheon Electronics
Semiconductor Division
5580 Morehouse Drive
San Diego, CA 92121
6194571000
8007227074
Fax 6194556314
applications@lj.sd.ray.com

